home *** CD-ROM | disk | FTP | other *** search
/ Languguage OS 2 / Languguage OS II Version 10-94 (Knowledge Media)(1994).ISO / gnu / uucp-doc.lha / uucp-doc-1.04 / uucp.info-2 (.txt) < prev    next >
GNU Info File  |  1993-02-14  |  51KB  |  973 lines

  1. This is Info file uucp.info, produced by Makeinfo-1.49 from the input
  2. file uucp.texi.
  3.    This file documents Taylor UUCP, version 1.04.
  4.    Copyright (C) 1992, 1993 Ian Lance Taylor
  5.    Permission is granted to make and distribute verbatim copies of this
  6. manual provided the copyright notice and this permission notice are
  7. preserved on all copies.
  8.    Permission is granted to copy and distribute modified versions of
  9. this manual under the conditions for verbatim copying, provided also
  10. that the section entitled "Copying" are included exactly as in the
  11. original, and provided that the entire resulting derived work is
  12. distributed under the terms of a permission notice identical to this
  13.    Permission is granted to copy and distribute translations of this
  14. manual into another language, under the above conditions for modified
  15. versions, except that the section entitled "Copying" may be included in
  16. a translation approved by the author instead of in the original English.
  17. File: uucp.info,  Node: Leaf Example,  Next: Gateway Example,  Prev: config File Examples,  Up: Configuration Examples
  18. Leaf Example
  19. ------------
  20.    A relatively common simple case is a "leaf site", a system which
  21. only calls or is called by a single remote site.  Here is a typical
  22. `sys' file that might be used in such a case.  For full details on what
  23. commands can appear in the `sys' file, see *Note sys File::.
  24.    This is the `sys' file that is used at `airs.com'.  We use a single
  25. modem to dial out to `uunet'.  This example shows how you can specify
  26. the port and dialer information directly in the `sys' file for simple
  27. cases.  It also shows the use of the following:
  28. `call-login'
  29.      Using `call-login' and `call-password' allows the default login
  30.      chat script to be used.  In this case, the login name is specified
  31.      in the call-out login file (*note Configuration File Names::.).
  32. `call-timegrade'
  33.      `uunet' is requested to not send us news during the daytime.
  34. `chat-fail'
  35.      If the modem returns `BUSY' or `NO CARRIER' the call is
  36.      immediately aborted.
  37. `protocol-parameter'
  38.      Since `uunet' tends to be slow, the default timeout has been
  39.      increased.
  40.    This `sys' file relies on certain defaults.  It will allow `uunet'
  41. to queue up `rmail' and `rnews' commands.  It will allow users to
  42. request files from `uunet' into the UUCP public directory.  It will
  43. also `uunet' to request files from the UUCP public directory; in fact
  44. `uunet' never requests files, but for additional security we could add
  45. the line `request false'.
  46.      # The following information is for uunet
  47.      system uunet
  48.      
  49.      # The login name and password are kept in the callout password file
  50.      call-login *
  51.      call-password *
  52.      
  53.      # We can send anything at any time.
  54.      time any
  55.      
  56.      # During the day we only accept grade `Z' or above; at other times
  57.      # (not mentioned here) we accept all grades.  uunet queues up news
  58.      # at grade `d', which is lower than `Z'.
  59.      call-timegrade Z Wk0755-2305,Su1655-2305
  60.      
  61.      # The phone number.
  62.      phone 7389449
  63.      
  64.      # uunet tends to be slow, so we increase the timeout
  65.      chat-timeout 120
  66.      
  67.      # We are using a preconfigured Telebit 2500.
  68.      port type modem
  69.      port device /dev/ttyd0
  70.      port baud 19200
  71.      port carrier true
  72.      port dialer chat "" ATZ\r\d\c OK ATDT\D CONNECT
  73.      port dialer chat-fail BUSY
  74.      port dialer chat-fail NO\sCARRIER
  75.      port dialer complete \d\d+++\d\dATH\r\c
  76.      port dialer abort \d\d+++\d\dATH\r\c
  77.      
  78.      # Increase the timeout and the number of retries.
  79.      protocol-parameter g timeout 20
  80.      protocol-parameter g retries 10
  81. File: uucp.info,  Node: Gateway Example,  Prev: Leaf Example,  Up: Configuration Examples
  82. Gateway Example
  83. ---------------
  84.    Many organizations have several local machines which are connected by
  85. UUCP, and a single machine which connects to the outside world.  This
  86. single machine is often referred to as a "gateway" machine.
  87.    For this example I will assume a fairly simple case.  It should still
  88. provide a good general example.  There are three machines, `elmer',
  89. `comton' and `bugs'.  `elmer' is the gateway machine for which I will
  90. show the configuration file.  `elmer' calls out to `uupsi'.  As an
  91. additional complication, `uupsi' knows `elmer' as `airs'; this will
  92. show how a machine can have one name on an internal network but a
  93. different name to the external world. `elmer' has two modems.  It also
  94. has an TCP/IP connection to `uupsi', but since that is supposed to be
  95. reserved for interactive work (it is, perhaps, only a 9600 baud SLIP
  96. line) it will only use it if the modems are not available.
  97.    A network this small would normally use a single `sys' file.
  98. However, for pedagogical purposes I will show two separate `sys' files,
  99. one for the local systems and one for `uupsi'.  This is done with the
  100. `sysfile' command in the `config' file.  Here is the `config' file.
  101.      # This is config
  102.      # The local sys file
  103.      sysfile /usr/local/lib/uucp/sys.local
  104.      # The remote sys file
  105.      sysfile /usr/local/lib/uucp/sys.remote
  106.    Using the defaults feature of the `sys' file can greatly simplify
  107. the listing of local systems.  Here is `sys.local'.  Note that this
  108. assumes that the local systems are trusted; they are permited to request
  109. any world readable file and to write files into any world writable
  110. directory.
  111.      # This is sys.local
  112.      # Get the login name and password to use from the call-out file
  113.      call-login *
  114.      call-password *
  115.      
  116.      # The systems must use a particular login
  117.      called-login Ulocal
  118.      
  119.      # Permit sending any world readable file
  120.      local-send /
  121.      remote-send /
  122.      
  123.      # Permit requesting into any world writable directory
  124.      local-receive /
  125.      remote-receive /
  126.      
  127.      # Call at any time
  128.      time any
  129.      
  130.      # Use port1, then port2
  131.      port port1
  132.      
  133.      alternate
  134.      
  135.      port port2
  136.      
  137.      # Now define the systems themselves.  Because of all the defaults we
  138.      # used, there is very little to specify for the systems themselves.
  139.      
  140.      system comton
  141.      phone 5551212
  142.      
  143.      system bugs
  144.      phone 5552424
  145.    The `sys.remote' file describes the `uupsi' connection.  The
  146. `myname' command is used to change the UUCP name to `airs' when talking
  147. to `uupsi'.
  148.      # This is sys.remote
  149.      # Define uupsi
  150.      system uupsi
  151.      
  152.      # The login name and password are in the call-out file
  153.      call-login *
  154.      call-password *
  155.      
  156.      # We can call out at any time
  157.      time any
  158.      
  159.      # uupsi uses a special login name
  160.      called-login Uuupsi
  161.      
  162.      # uuspi thinks of us as `airs'
  163.      myname airs
  164.      
  165.      # The phone number
  166.      phone 5554848
  167.      
  168.      # We use port2 first, then port1, then TCP
  169.      
  170.      port port2
  171.      
  172.      alternate
  173.      
  174.      port port1
  175.      
  176.      alternate
  177.      
  178.      # We don't bother to make a special entry in the port file for TCP, we
  179.      # just describe the entire port right here.  We use a special chat
  180.      # script over TCP because the usual one confuses some TCP servers.
  181.      port type TCP
  182.      address uu.psi.com
  183.      chat ogin: \L word: \P
  184.    The ports are defined in the file `port' (*note port File::.).  For
  185. this example they are both connected to the same type of 2400 baud
  186. Hayes-compatible modem.
  187.      # This is port
  188.      
  189.      port port1
  190.      type modem
  191.      device /dev/ttyd0
  192.      dialer hayes
  193.      speed 2400
  194.      
  195.      port port2
  196.      type modem
  197.      device /dev/ttyd1
  198.      dialer hayes
  199.      speed 2400
  200.    Dialers are described in the `dial' file (*note dial File::.).
  201.      # This is dial
  202.      
  203.      dialer hayes
  204.      
  205.      # The chat script used to dial the phone.  \D is the phone number.
  206.      chat "" ATZ\r\d\c OK ATDT\D CONNECT
  207.      
  208.      # If we get BUSY or NO CARRIER we abort the dial immediately
  209.      chat-fail BUSY
  210.      chat-fail NO\sCARRIER
  211.      
  212.      # When the call is over we make sure we hangup the modem.
  213.      complete \d\d+++\d\dATH\r\c
  214.      abort \d\d+++\d\dATH\r\c
  215. File: uucp.info,  Node: Time Strings,  Next: Chat Scripts,  Prev: Configuration Examples,  Up: Configuration Files
  216. Time Strings
  217. ============
  218.    Several commands use time strings to specify a range of times.  This
  219. section describes how to write time strings.
  220.    A time string may be a list of simple time strings separated with a
  221. vertical bar `|' or a comma `,'.
  222.    Each simple time string must begin with `Su', `Mo', `Tu', `We',
  223. `Th', `Fr', or `Sa', or `Wk' for any weekday, or `Any' for any day.
  224.    Following the day may be a range of hours separated with a hyphen
  225. using 24 hour time.  The range of hours may cross 0; for example
  226. `2300-0700' means any time except 7 AM to 11 PM.  If no time is given,
  227. calls may be made at any time on the specified day(s).
  228.    The time string may also consist of the single word `Never', which
  229. does not match any time, or a single word with a name defined in a
  230. previous `timetable' command (*note Miscellaneous (config)::.).
  231.    Here are a few sample time strings with an explanation of what they
  232. mean.
  233. `Wk2305-0855,Sa,Su2305-1655'
  234.      This means weekdays before 8:55 AM or after 11:05 PM, any time
  235.      Saturday, or Sunday before 4:55 PM or after 11:05 PM.  These are
  236.      approximately the times during which night rates apply to phone
  237.      calls in the U.S.A.  Note that this time string uses, for example,
  238.      `2305' rather than `2300'; this will ensure a cheap rate phone
  239.      call even if the computer clock is running up to five minutes
  240.      ahead of the real time.
  241. `Wk0905-2255,Su1705-2255'
  242.      This means weekdays from 9:05 AM to 10:55 PM, or Sunday from 5:05
  243.      PM to 10:55 PM.  This is approximately the opposite of the
  244.      previous example.
  245. `Any'
  246.      This means any day.  Since no time is specified, it means any time
  247.      on any day.
  248. File: uucp.info,  Node: Chat Scripts,  Next: config File,  Prev: Time Strings,  Up: Configuration Files
  249. Chat Scripts
  250. ============
  251.    Chat scripts are used in several different places, such as dialing
  252. out on modems or logging in to remote systems.  Chat scripts are made
  253. up of pairs of strings.  The program waits until it sees the first
  254. string, known as the "expect" string, and then sends out the second
  255. string, the "send" string.
  256.    Each chat script is defined using a set of commands.  These commands
  257. always end in a string beginning with `chat', but may start with
  258. different strings.  For example, in the `sys' file there is one set of
  259. commands beginning with `chat' and another set beginning with
  260. `called-chat'.  The prefixes are only used to disambiguate different
  261. types of chat scripts, and this section ignores the prefixes when
  262. describing the commands.
  263. `chat STRINGS'
  264.      Specify a chat script.  The arguments to the `chat' command are
  265.      pairs of strings separated by whitespace.  The first string of
  266.      each pair is an expect string, the second is a send string.  The
  267.      program will wait for the expect string to appear; when it does,
  268.      the program will send the send string.  If the expect string does
  269.      not appear within a certain number of seconds (as set by the
  270.      `chat-timeout' command) the chat script fails and, typically, the
  271.      call is aborted.  If the final expect string is seen (and the
  272.      optional final send string has been sent), the chat script is
  273.      successful.
  274.      An expect string may contain additional subsend and subexpect
  275.      strings, separated by hyphens.  If the expect string is not seen,
  276.      the subsend string is sent and the chat script continues by
  277.      waiting for the subexpect string.  This means that a hyphen may
  278.      not appear in an expect string; on an ASCII system, use `\055'
  279.      instead.
  280.      An expect string may simply be `""', meaning to skip the expect
  281.      phase.  Otherwise, the following escape characters may appear in
  282.      expect strings:
  283.     `\b'
  284.           a backspace character
  285.     `\n'
  286.           a newline or line feed character
  287.     `\N'
  288.           a null character (for HDB compatibility)
  289.     `\r'
  290.           a carriage return character
  291.     `\s'
  292.           a space character
  293.     `\t'
  294.           a tab character
  295.     `\\'
  296.           a backslash character
  297.     `\DDD'
  298.           character DDD, where DDD are up to three octal digits
  299.     `\xDDD'
  300.           character DDD, where DDD are hexadecimal digits.
  301.      As in C, there may be up to three octal digits following a
  302.      backslash, but the hexadecimal escape sequence continues as far as
  303.      possible.  To follow a hexadecimal escape sequence with a hex
  304.      digit, interpose a send string of `""'.
  305.      A send string may simply be `""' to skip the send phase.
  306.      Otherwise, all of the escape characters legal for expect strings
  307.      may be used, and the following escape characters are also
  308.      permitted:
  309.     `EOT'
  310.           send an end of transmission character (`^D')
  311.     `BREAK'
  312.           send a break character (may not work on all systems)
  313.     `\c'
  314.           suppress trailing carriage return at end of send string
  315.     `\d'
  316.           delay sending for 1 or 2 seconds
  317.     `\e'
  318.           disable echo checking
  319.     `\E'
  320.           enable echo checking
  321.     `\K'
  322.           same as `BREAK' (for HDB compatibility)
  323.     `\p'
  324.           pause sending for a fraction of a second
  325.      Some specific types of chat scripts also define additional escape
  326.      sequences that may appear in the send string.  For example, the
  327.      login chat script defines `\L' and `\P' to send the login name and
  328.      password, respectively.
  329.      A carriage return will be sent at the end of each send string,
  330.      unless the `\c' escape sequence appears in the string.  Note that
  331.      some UUCP packages use `\b' for break, but here it means backspace.
  332.      Echo checking means that after writing each character the program
  333.      will wait until the character is echoed.  Echo checking must be
  334.      turned on separately for each send string for which it is desired;
  335.      it will be turned on for characters following `\E' and turned off
  336.      for characters following `\e'.
  337. `chat-timeout NUMBER'
  338.      The number of seconds to wait for an expect string in the chat
  339.      script before timing out and sending the next subsend or failing
  340.      the chat script entirely.  The default value is 10 for a login
  341.      chat or 60 for any other type of chat.
  342. `chat-fail STRING'
  343.      If the STRING is seen at any time during a chat script, the chat
  344.      script is aborted.  The string may not contain any whitespace
  345.      characters; escape sequences must be used for them.  Multiple
  346.      `chat-fail' commands may appear in a single chat script.  The
  347.      default is to have none.
  348.      This permits a chat script to be quickly aborted if an error
  349.      string is seen.  For example, a script used to dial out on a modem
  350.      might use the command `chat-fail BUSY' to stop the chat script
  351.      immediately if the string `BUSY' was seen.
  352. `chat-seven-bit BOOLEAN'
  353.      If the argument is true, all incoming characters are stripped to
  354.      seven bits when being compared to the expect string.  Otherwise
  355.      all eight bits are used in the comparison.  The default is true,
  356.      because some Unix systems generate parity bits during the login
  357.      prompt which must be ignored while running a chat script.  This
  358.      has no effect on any `chat-program', which must ignore parity by
  359.      itself if necessary.
  360. `chat-program STRINGS'
  361.      Specify a program to run before executing the chat script.  This
  362.      program could run its own version of a chat script, or it could do
  363.      whatever it wants.  If both `chat-program' and `chat' are
  364.      specified, the program is executed first followed by the chat
  365.      script.
  366.      The first argument to the `chat-program' command is the program
  367.      name to run.  The remaining arguments are passed to the program. 
  368.      The following escape sequences are recognized in the arguments:
  369.     `\Y'
  370.           port device name
  371.     `\S'
  372.           port speed
  373.     `\\'
  374.           backslash
  375.      Some specific uses of `chat-program' define additional escape
  376.      sequences.
  377.      Arguments other than escape sequences are passed exactly as they
  378.      appear in the configuration file, except that sequences of
  379.      whitespace are compressed to a single space character (this
  380.      exception may be removed in the future).
  381.      If the `chat-program' command is not used, no program is run.
  382.      On Unix, the standard input and standard output of the program
  383.      will be attached to the port in use.  Anything the program writes
  384.      to standard error will be written to the UUCP log file.  No other
  385.      file descriptors will be open.  If the program does not exit with
  386.      a status of 0, it will be assumed to have failed; this means that
  387.      the dialing programs used by some versions of HDB may not be used
  388.      directly, although of course a shell script could be used as an
  389.      interface.
  390.      The program will be run as the `uucp' user, and the environment
  391.      will be that of the process that started `uucico', so care must be
  392.      taken to maintain security.
  393.      No search path is used to find the program; a full path name must
  394.      be given.  If the program is an executable shell script, it will
  395.      be passed to `/bin/sh' even on systems which are unable to execute
  396.      shell scripts.  It is also easy to invoke `/bin/sh' directly.
  397.    Here is a simple example of a chat script that might be used to
  398. reset a Hayes compatible modem.
  399.      chat "" ATZ OK-ATZ-OK
  400.    The first expect string is `""', so it is ignored.  The chat script
  401. then sends `ATZ'.  If the modem responds with `OK', the chat script
  402. finishes.  If 60 seconds (the default timeout) pass before seeing `OK',
  403. the chat script sends another `ATZ'.  If it then sees `OK', the chat
  404. script succeeds.  Otherwise, the chat script fails.
  405.    For a more complex chat script example, see *Note Logging In::.
  406. File: uucp.info,  Node: config File,  Next: sys File,  Prev: Chat Scripts,  Up: Configuration Files
  407. The Main Configuration File
  408. ===========================
  409.    The main configuration file is named `config'.
  410.    Since all the values that may be specified in the main configuration
  411. file also have defaults, there need not be a main configuration file at
  412. * Menu:
  413. * Miscellaneous (config)::      Miscellaneous config file commands
  414. * Configuration File Names::    Using different configuration files
  415. * Log File Names::              Using different log files
  416. * Debugging Levels::            Debugging levels
  417. File: uucp.info,  Node: Miscellaneous (config),  Next: Configuration File Names,  Prev: config File,  Up: config File
  418. Miscellaneous config File Commands
  419. ----------------------------------
  420. `nodename STRING'
  421. `hostname STRING'
  422. `uuname STRING'
  423.      These keywords are equivalent.  They specify the UUCP name of the
  424.      local host.  If there is no configuration file, an appropriate
  425.      system function will be used to get the host name, if possible.
  426. `spool STRING'
  427.      Specify the spool directory.  The default is from `policy.h'.  This
  428.      is where UUCP files are queued.  Status files and various sorts of
  429.      temporary files are also stored in this directory and
  430.      subdirectories of it.
  431. `pubdir STRING'
  432.      Specify the public directory.  The default is from `policy.h'.
  433.      When a file is named using a leading `~/', it is taken from or to
  434.      the public directory.  Each system may use a separate public
  435.      directory by using the `pubdir' command in the system
  436.      configuration file; see *Note Miscellaneous (sys)::.
  437. `lockdir STRING'
  438.      Specify the directory to place lock files in.  The default is from
  439.      `policy.h'; see the information in that file.  Normally the lock
  440.      directory should be set correctly in `policy.h', and not changed
  441.      here.  However, changing the lock directory is sometimes useful for
  442.      testing purposes.
  443. `unknown STRING ...'
  444.      The STRING and subsequent arguments are treated as though they
  445.      appeared in the system file (*note sys File::.).  They are used to
  446.      apply to any unknown systems that may call in, probably to set
  447.      file transfer permissions and the like.  If the `unknown' command
  448.      is not used, unknown systems are not permitted to call in.
  449. `max-uuxqts NUMBER'
  450.      Specify the maximum number of `uuxqt' processes which may run at
  451.      the same time.  Having several `uuxqt' processes running at once
  452.      can significantly slow down a system, but since `uuxqt' is
  453.      automatically started by `uucico', it can happen quite easily.  The
  454.      default for `max-uuxqts' is 0, which means that there is no limit.
  455.      If HDB configuration files are being read and the code was compiled
  456.      without `HAVE_TAYLOR_CONFIG', then if the file `Maxuuxqts' in the
  457.      configuration directory contains a readable number it will be used
  458.      as the value for `max-uuxqts'.
  459. `timetable STRING STRING'
  460.      The `timetable' defines a timetable that may be used in
  461.      subsequently appearing time strings; *Note Time Strings::.  The
  462.      first string names the timetable entry; the second is a time
  463.      string.
  464.      The following `timetable' commands are predefined.  The NonPeak
  465.      timetable is included for compatibility.  It originally described
  466.      the offpeak hours of Tymnet and Telenet, but both have since
  467.      changed their schedules.
  468.           timetable Evening Wk1705-0755,Sa,Su
  469.           timetable Night Wk2305-0755,Sa,Su2305-1655
  470.           timetable NonPeak Wk1805-0655,Sa,Su
  471.      If this command does not appear, then obviously no additional
  472.      timetables will be defined.
  473. `v2-files BOOLEAN'
  474.      If the code was compiled to be able to read V2 configuration
  475.      files, a false argument to this command will prevent them from
  476.      being read. This can be useful while testing.  The default is true.
  477. `hdb-files BOOLEAN'
  478.      If the code was compiled to be able to read HDB configuration
  479.      files, a false argument to this command will prevent them from
  480.      being read. This can be useful while testing.  The default is true.
  481. File: uucp.info,  Node: Configuration File Names,  Next: Log File Names,  Prev: Miscellaneous (config),  Up: config File
  482. Configuration File Names
  483. ------------------------
  484. `sysfile STRINGS'
  485.      Specify the system file(s).  The default is the file `sys' in the
  486.      directory NEWCONFIGDIR.  These files hold information about other
  487.      systems with which this system communicates; see *Note sys File::.
  488.      Multiple system files may be given on the line, and the `sysfile'
  489.      command may be repeated; each system file has its own set of
  490.      defaults.
  491. `portfile STRINGS'
  492.      Specify the port file(s).  The default is the file `port' in the
  493.      directory NEWCONFIGDIR.  These files describe ports which are used
  494.      to call other systems and accept calls from other systems; see
  495.      *Note port File::.  No port files need be named at all.  Multiple
  496.      port files may be given on the line, and the `portfile' command
  497.      may be repeated.
  498. `dialfile STRINGS'
  499.      Specify the dial file(s).  The default is the file `dial' in the
  500.      directory NEWCONFIGDIR.  These files describe dialing devices
  501.      (modems); *Note dial File::.  No dial files need be named at all.
  502.      Multiple dial files may be given on the line, and the `dialfile'
  503.      command may be repeated.
  504. `dialcodefile STRINGS'
  505.      Specify the dialcode file(s).  The default is the file `dialcode'
  506.      in the directory NEWCONFIGDIR.  These files specify dialcodes that
  507.      may be used when sending phone numbers to a modem.  This permits
  508.      using the same set of phone numbers in different area-codes or
  509.      with different phone systems, by using dialcodes to specify the
  510.      calling sequence.  When a phone number goes through dialcode
  511.      translation, the leading alphabetic characters are stripped off. 
  512.      The dialcode files are read line by line, just like any other
  513.      configuration file, and when a line is found whose first word is
  514.      the same as the leading characters from the phone number, the
  515.      second word on the line (which would normally consist of numbers)
  516.      replaces the dialcode in the phone number.  No dialcode file need
  517.      be used.  Multiple dialcode files may be specified on the line,
  518.      and the `dialcodefile' command may be repeated; all the dialcode
  519.      files will be read in turn until a dialcode is located.
  520. `callfile STRINGS'
  521.      Specify the call out login name and password file(s).  The default
  522.      is the file `call' in the directory NEWCONFIGDIR.  If the call out
  523.      login name or password for a system are given as `*' (*note
  524.      Logging In::.), these files are read to get the real login name or
  525.      password.  Each line in the file(s) has three words: the system
  526.      name, the login name, and the password.  This file is only used
  527.      when placing calls to remote systems; the password file described
  528.      under `passwdfile' below is used for incoming calls.  The
  529.      intention of the call out file is to permit the system file to be
  530.      publically readable; the call out files must obviously be kept
  531.      secure.  These files need not be used.  Multiple call out files
  532.      may be specified on the line, and the `callfile' command may be
  533.      repeated; all the files will be read in turn until the system is
  534.      found.
  535. `passwdfile STRINGS'
  536.      Specify the password file(s) to use for login names when `uucico'
  537.      is doing its own login prompting, which it does when given the
  538.      `-e', `-l' or `-w' switches.  The default is the file `passwd' in
  539.      the directory NEWCONFIGDIR.  Each line in the file(s) has two
  540.      words: the login name and the password (e.g. `Ufoo foopas').  The
  541.      login name is accepted before the system name is known, so these
  542.      are independent of which system is calling in; a particular login
  543.      may be required for a system by using the `called-login' command
  544.      in the system file (*note Accepting a Call::.).  These password
  545.      files are optional, although one must exist if `uucico' is to
  546.      present its own login prompts.  Multiple password files may be
  547.      specified on the line, and the `passwdfile' command may be
  548.      repeated; all the files will be read in turn until the login name
  549.      is found.
  550. File: uucp.info,  Node: Log File Names,  Next: Debugging Levels,  Prev: Configuration File Names,  Up: config File
  551. Log File Names
  552. --------------
  553. `logfile STRING'
  554.      Name the log file.  The default is from `policy.h'.  Logging
  555.      information is written to this file.  If `HAVE_HDB_LOGGING' is
  556.      defined in `conf.h', then by default a separate log file is used
  557.      for each system.  Using this command to name a log file will cause
  558.      all the systems to use it.
  559. `statfile STRING'
  560.      Name the statistics file.  The default is from `policy.h'.
  561.      Statistical information about file transfers is written to this
  562.      file.
  563. `debugfile STRING'
  564.      Name the file to which debugging information is written.  The
  565.      default is from `policy.h'.  This command is only effective if the
  566.      code has been compiled to include debugging (this is controlled by
  567.      the `DEBUG' variable in `policy.h').  After the first debugging
  568.      message has been written, messages written to the log file are also
  569.      written to the debugging file to make it easier to keep the order
  570.      of actions straight.  The debugging file is different from the log
  571.      file because information such as passwords can appear in it, so it
  572.      must be not be publically readable.
  573. File: uucp.info,  Node: Debugging Levels,  Prev: Log File Names,  Up: config File
  574. Debugging Levels
  575. ----------------
  576. `debug STRING ...'
  577.      Set the debugging level.  This command is only effective if the
  578.      code has been compiled to include debugging.  The default is to
  579.      have no debugging.  The arguments are strings which name the types
  580.      of debugging to be turned on.  The following types of debugging
  581.      are defined:
  582.     `abnormal'
  583.           Output debugging messages for abnormal situations, such as
  584.           recoverable errors.
  585.     `chat'
  586.           Output debugging messages for chat scripts.
  587.     `handshake'
  588.           Output debugging messages for the initial handshake.
  589.     `uucp-proto'
  590.           Output debugging messages for the UUCP session protocol.
  591.     `proto'
  592.           Output debugging messages for the individual link protocols.
  593.     `port'
  594.           Output debugging messages for actions on the communication
  595.           port.
  596.     `config'
  597.           Output debugging messages while reading the configuration
  598.           files.
  599.     `spooldir'
  600.           Output debugging messages for actions in the spool directory.
  601.     `execute'
  602.           Output debugging messages whenever another program is
  603.           executed.
  604.     `incoming'
  605.           List all incoming data in the debugging file.
  606.     `outgoing'
  607.           List all outgoing data in the debugging file.
  608.     `all'
  609.           All of the above.
  610.      The debugging level may also be specified as a number.  A 1 will
  611.      set `chat' debugging, a 2 will set both `chat' and `handshake'
  612.      debugging, and so on down the possibilities.  Currently an 11 will
  613.      turn on all possible debugging, since there are 11 types of
  614.      debugging messages listed above; more debugging types may be added
  615.      in the future.  The `debug' command may be used several times in
  616.      the configuration file; every debugging type named will be turned
  617.      on.  When running any of the programs, the `-x' switch (actually,
  618.      for `uulog' it's the `-X' switch) may be used to turn on
  619.      debugging.  The argument to the `-x' switch is one of the strings
  620.      listed above, or a number as described above, or a comma separated
  621.      list of strings (e.g.  `-x chat,handshake').  The `-x' switch may
  622.      also appear several times on the command line, in which case all
  623.      named debugging types will be turned on.  The `-x' debugging is in
  624.      addition to any debugging specified by the `debug' command; there
  625.      is no way to cancel debugging information.  The debugging level
  626.      may also be set specifically for calls to or from a specific
  627.      system with the `debug' command in the system file (*note
  628.      Miscellaneous (sys)::.).
  629.      The debugging messages are somewhat idiosyncratic; it may be
  630.      necessary to refer to the source code for additional information
  631.      in some cases.
  632. File: uucp.info,  Node: sys File,  Next: port File,  Prev: config File,  Up: Configuration Files
  633. The System Configuration File
  634. =============================
  635.    By default there is a single system configuration, named `sys' in
  636. the directory NEWCONFIGDIR.  This may be overridden by the `sysfile'
  637. command in the main configuration file; see *Note Configuration File
  638. Names::.
  639.    These files describe all remote systems known to the UUCP package.
  640. * Menu:
  641. * Defaults and Alternates::     Using defaults and alternates
  642. * Naming the System::           Naming the system
  643. * Calling Out::                 Calling out
  644. * Accepting a Call::            Accepting a call
  645. * Protocol Selection::          Protocol selection
  646. * File Transfer Control::       File transfer control
  647. * Miscellaneous (sys)::         Miscellaneous sys file commands
  648. * Default sys File Values::     Default values
  649. File: uucp.info,  Node: Defaults and Alternates,  Next: Naming the System,  Prev: sys File,  Up: sys File
  650. Defaults and Alternates
  651. -----------------------
  652.    The first set of commands in the file, up to the first `system'
  653. command, specify defaults to be used for all systems in that file.  Each
  654. system file uses a different set of defaults.
  655.    Subsequently, each set of commands from `system' up to the next
  656. `system' command describe a particular system.  Default values may be
  657. overridden for specific systems.
  658.    Each system may then have a series of alternate choices to use when
  659. calling out or calling in.  The first set of commands for a particular
  660. system, up to the first `alternate' command, provide the first choice. 
  661. Subsequently, each set of commands from `alternate' up to the next
  662. `alternate' command describe an alternate choice for calling out or
  663. calling in.
  664.    When a system is called, the commands before the first `alternate'
  665. are used to select a phone number, port, and so forth; if the call fails
  666. for some reason, the commands between the first `alternate' and the
  667. second are used, and so forth.  Well, not quite.  Actually, each
  668. succeeding alternate will only be used if it is different in some
  669. relevant way (different phone number, different chat script, etc.).  If
  670. you want to force the same alternate to be used again (to retry a phone
  671. call more than once, for example), enter the phone number (or any other
  672. relevant field) again to make it appear different.
  673.    The alternates can also be used to give different permissions to an
  674. incoming call based on the login name.  This will only be done if the
  675. first set of commands, before the first `alternate' command, uses the
  676. `called-login' command.  The list of alternates will be searched, and
  677. the first alternate with a matching `called-login' command will be
  678. used.  If no alternates match, the call will be rejected.
  679.    The `alternate' command may also be used in the file-wide defaults
  680. (the set of commands before the first `system' command).  This might be
  681. used to specify a list of ports which are available for all systems
  682. (for an example of this, see *Note Gateway Example::) or to specify
  683. permissions based on the login name used by the remote system when it
  684. calls in.  The first alternate for each system will default to the
  685. first alternate for the file-wide defaults (as modified by the commands
  686. used before the first `alternate' command for this system), the second
  687. alternate for each system to the second alternate for the file-wide
  688. defaults (as modified the same way), and so forth.  If a system
  689. specifies more alternates than the file-wide defaults, the trailing
  690. ones will default to the last file-wide default alternate.  If a system
  691. specifies fewer alternates than the file-wide defaults, the trailing
  692. file-wide default alternates will be used unmodified.  The
  693. `default-alternates' command may be used to modify this behaviour.
  694.    This can all get rather confusing, although it's easier to use than
  695. to describe concisely; the `uuchk' program may be used to ensure that
  696. you are getting what you want.
  697. File: uucp.info,  Node: Naming the System,  Next: Calling Out,  Prev: Defaults and Alternates,  Up: sys File
  698. Naming the System
  699. -----------------
  700. `system STRING'
  701.      Specify the remote system name.  Subsequent commands up to the next
  702.      `system' command refer to this system.
  703. `alternate [STRING]'
  704.      Start an alternate set of commands (*note Defaults and
  705.      Alternates::.). An optional argument may be used to name the
  706.      alternate.  This name will be put in the log file if the alternate
  707.      is used to call the system. There is no way to name the first
  708.      alternate (the commands before the first `alternate' command).
  709. `default-alternates BOOLEAN'
  710.      If the argument is false, any remaining default alternates (from
  711.      the defaults specified at the top of the current system file) will
  712.      not be used.  The default is true.
  713. `alias STRING'
  714.      Specify an alias for the current system.  The alias may be used by
  715.      local `uucp' and `uux' commands, as well as by the remote system
  716.      (which can be convenient if a remote system changes its name).  The
  717.      default is to have no aliases.
  718. `myname STRING'
  719.      Specifies a different system name to use when calling the remote
  720.      system. Also, if `called-login' is used and is not `ANY', then,
  721.      when a system logs in with that login name, STRING is used as the
  722.      system name.  Because the local system name must be determined
  723.      before the remote system has identified itself, using `myname' and
  724.      `called-login' together for any system will set the local name for
  725.      that login; this means that each locally used system name must
  726.      have a unique login name associated with it.  This allows a system
  727.      to have different names for an external and an internal network. 
  728.      The default is to not use a special local name.
  729. File: uucp.info,  Node: Calling Out,  Next: Accepting a Call,  Prev: Naming the System,  Up: sys File
  730. Calling Out
  731. -----------
  732.    This section describes commands used when placing a call to another
  733. system.
  734. * Menu:
  735. * When to Call::                When to call
  736. * Placing the Call::            Placing the call
  737. * Logging In::                  Logging in
  738. File: uucp.info,  Node: When to Call,  Next: Placing the Call,  Prev: Calling Out,  Up: Calling Out
  739. When to Call
  740. ............
  741. `time STRING [NUMBER]'
  742.      Specify when the system may be called.  The first argument is a
  743.      time string; see *Note Time Strings::.  The optional second
  744.      argument specifies a retry time in minutes.  If a call made during
  745.      a time that matches the time string fails, no more calls are
  746.      permitted until the retry time has passed.  By default an
  747.      exponentially increasing retry time is used: after each failure
  748.      the next retry period is longer.  A retry time specified in the
  749.      `time' command is always a fixed amount of time.
  750.      The `time' command may appear multiple times in a single alternate,
  751.      in which case if any time string matches the system may be called.
  752.       When the `time' command is used for a particular system, any
  753.      `time' or `timegrade' commands that appeared in the system
  754.      defaults are ignored.
  755.      The default time string is `Never'.
  756. `timegrade CHARACTER STRING [NUMBER]'
  757.      The CHARACTER specifies a grade.  It must be a single letter or
  758.      digit.  The STRING is a time string (*note Time Strings::.).  All
  759.      jobs of grade CHARACTER or higher (where `0' > `9' > `A' > `Z' >
  760.      `a' > `z') may be run at the specified time. An ordinary `time'
  761.      command is equivalent to using `timegrade' with a grade of `z',
  762.      permitting all jobs.  If there are no jobs of a sufficiently high
  763.      grade according to the time string, the system will not be called.
  764.       Giving the `-s' switch to `uucico' to force it to call a system
  765.      causes it to assume there is a job of grade `0' waiting to be run.
  766.      The optional third argument specifies a retry time in minutes. 
  767.      See the `time' command, above, for more details.
  768.      Note that the `timegrade' command serves two purposes: 1) if there
  769.      is no job of sufficiently high grade the system will not be
  770.      called, and 2) if the system is called anyway (because the `-s'
  771.      switch was given to `uucico') only jobs of sufficiently high grade
  772.      will be transferred.  However, if the other system calls in, the
  773.      `timegrade' commands are ignored, and jobs of any grade may be
  774.      transferred (but see `call-timegrade' below).  Also, the
  775.      `timegrade' command will not prevent the other system from
  776.      transferring any job it chooses, regardless of who placed the call.
  777.      The `timegrade' command may appear multiple times without using
  778.      `alternate'.  When the `timegrade' command is used for a
  779.      particular system, any `time' or `timegrade' commands that
  780.      appeared in the system defaults are ignored.
  781.      If this command does not appear, there are no restrictions on what
  782.      grade of work may be done at what time.
  783. `max-retries NUMBER'
  784.      Gives the maximum number of times this system may be retried.  If
  785.      this many calls to the system fail, it will be called at most once
  786.      a day whatever the retry time is.  The default is 26.
  787. `success-wait NUMBER'
  788.      A retry time, in seconds, which applies after a successful call. 
  789.      This can be used to put a limit on how frequently the system is
  790.      called.  For example, an argument of 1800 means that the system
  791.      will not be called more than once every half hour.  The default is
  792.      0, which means that there is no limit.
  793. `call-timegrade CHARACTER STRING'
  794.      The CHARACTER is a single character `A' to `Z', `a' to `z', or `0'
  795.      to `9' and specifies a grade.  The STRING is a time string as
  796.      described under the `time' command.  If a call is placed to the
  797.      other system during a time which matches the time string, the
  798.      remote system will be requested to only run jobs of grade
  799.      CHARACTER or higher.  Unfortunately, there is no way to guarantee
  800.      that the other system will obey the request (this UUCP package
  801.      will, but there are others which will not); moreover job grades
  802.      are historically somewhat arbitrary, so specifying a grade will
  803.      only be meaningful if the other system cooperates in assigning
  804.      grades.  This grade restriction only applies when the other system
  805.      is called, not when the other system calls in.
  806.      The `call-timegrade' command may appear multiple times without
  807.      using `alternate'.  If this command does not appear, or if none of
  808.      the time strings match, the remote system will be allowed to send
  809.      whatever grades of work it chooses.
  810. File: uucp.info,  Node: Placing the Call,  Next: Logging In,  Prev: When to Call,  Up: Calling Out
  811. Placing the Call
  812. ................
  813. `baud NUMBER'
  814. `speed NUMBER'
  815.      Specify the speed (the term "baud" is technically incorrect, but
  816.      widely understood) at which to call the system.  This will try all
  817.      available ports with that baud rate until an unlocked port is
  818.      found. The ports are defined in the port file.  If both `baud' and
  819.      `port' commands appear, both are used when selecting a port.  To
  820.      allow calls at more than one baud rate, the `alternate' command
  821.      must be used (*note Defaults and Alternates::.).  If this command
  822.      does not appear, there is no default; the baud rate may be
  823.      specified in the port file, but if it is not then the natural baud
  824.      rate of the port will be used (whatever that means on the system).
  825.       Specifying an explicit baud rate of 0 will request the natural
  826.      baud rate of the port, overriding any default baud rate from the
  827.      defaults at the top of the file.
  828. `port STRING'
  829.      Name a particular port or type of port to use when calling the
  830.      system. The information for this port is obtained from the port
  831.      file.  If this command does not appear, there is no default; a
  832.      port must somehow be specified in order to call out (it may be
  833.      specified implicitly using the `baud' command or explicitly using
  834.      the next version of `port').  There may be many ports with the
  835.      same name; each will be tried in turn until an unlocked one is
  836.      found which matches the desired baud rate.
  837. `port STRING ...'
  838.      If more than one string follows the `port' command, the strings are
  839.      treated as a command that might appear in the port file (*note
  840.      port File::.).  If a port is named (by using a single string
  841.      following `port') these commands are ignored; their purpose is to
  842.      permit defining the port completely in the system file rather than
  843.      always requiring entries in two different files.  In order to call
  844.      out, a port must be specified using some version of the `port'
  845.      command, or by using the `baud' command to select ports from the
  846.      port file.
  847. `phone STRING'
  848. `address STRING'
  849.      Give a phone number to call (when using a modem port) or a remote
  850.      host to contact (when using a TCP or TLI port).  The commands
  851.      `phone' and `address' are equivalent; the duplication is intended
  852.      to provide a mnemonic choice depending on the type of port in use.
  853.      When used with a modem port, an `=' character in the phone number
  854.      means to wait for a secondary dial tone (although only some modems
  855.      support this); a `-' character means to pause while dialing for 1
  856.      second (again, only some modems support this).  If the system has
  857.      more than one phone number, each one must appear in a different
  858.      alternate. The `phone' command must appear in order to call out on
  859.      a modem; there is no default.
  860.      When used with a TCP port, the string names the host to contact. 
  861.      It may be a domain name or a numeric Internet address.  If no
  862.      address is specified, the system name is used.
  863.      When used with a TLI port, the string is treated as though it were
  864.      an expect string in a chat script, allowing the use of escape
  865.      characters (*note Chat Scripts::.).  The `dialer-sequence' command
  866.      in the port file may override this address (*note port File::.).
  867.      When used with a port that not a modem or TCP or TLI, this command
  868.      is ignored.
  869. File: uucp.info,  Node: Logging In,  Prev: Placing the Call,  Up: Calling Out
  870. Logging In
  871. ..........
  872. `chat STRINGS'
  873. `chat-timeout NUMBER'
  874. `chat-fail STRING'
  875. `chat-seven-bit BOOLEAN'
  876. `chat-program STRINGS'
  877.      These commands describe a chat script to use when logging on to a
  878.      remote system.  Chat scripts are explained in *Note Chat Scripts::.
  879.      Two additional escape sequences may be used in send strings.
  880.     `\L'
  881.           Send the login name, as set by the `call-login' command.
  882.     `\P'
  883.           Send the password, as set by the `call-password' command.
  884.      Three additional escape sequences may be used with the
  885.      `chat-program' command.  These are `\L' and `\P', which become the
  886.      login name and password, respectively, and `\Z', which becomes the
  887.      name of the system of being called.
  888.      The default chat script is:
  889.           chat "" \r\c ogin:-BREAK-ogin:-BREAK-ogin: \L word: \P
  890.      This will send a carriage return (the `\c' suppresses the
  891.      additional trailing carriage return that would otherwise be sent)
  892.      and waits for the string `ogin:' (which would be the last part of
  893.      the `login:' prompt supplied by a Unix system).  If it doesn't see
  894.      `ogin:', it sends a break and waits for `ogin:' again.  If it
  895.      still doesn't see `ogin:', it sends another break and waits for
  896.      `ogin:' again. If it still doesn't see `ogin:', the chat script
  897.      aborts and hangs up the phone.  If it does see `ogin:' at some
  898.      point, it sends the login name (as specified by the `call-login'
  899.      command) followed by a carriage return (since all send strings are
  900.      followed by a carriage return unless `\c' is used) and waits for
  901.      the string `word:' (which would be the last part of the
  902.      `Password:' prompt supplied by a Unix system).  If it sees
  903.      `word:', it sends the password and a carriage return, completing
  904.      the chat script.  The program will then enter the handshake phase
  905.      of the UUCP protocol.
  906.      This chat script will work for most systems, so you will only be
  907.      required to use the `call-login' and `call-password' commands. In
  908.      fact, in the file-wide defaults you could set defaults of
  909.      `call-login *' and `call-password *'; you would then just have to
  910.      make an entry for each system in the call-out login file.
  911.      Some systems seem to flush input after the `login:' prompt, so they
  912.      may need a version of this chat script with a `\d' before the
  913.      `\L'.  When using UUCP over TCP, some servers will not be handle
  914.      the initial carriage return sent by this chat script; in this case
  915.      you may have to specify the simple chat script `ogin: \L word: \P'.
  916. `call-login STRING'
  917.      Specify the login name to send with `\L' in the chat script.  If
  918.      the string is `*' (e.g. `call-login *') the login name will be
  919.      fetched from the call out login name and password file (*note
  920.      Configuration File Names::.).  There is no default.
  921. `call-password STRING'
  922.      Specify the password to send with `\P' in the chat script.  If the
  923.      string is `*' (e.g. `call-password *') the password will be
  924.      fetched from the call-out login name and password file (*note
  925.      Configuration File Names::.).  There is no default.
  926. File: uucp.info,  Node: Accepting a Call,  Next: Protocol Selection,  Prev: Calling Out,  Up: sys File
  927. Accepting a Call
  928. ----------------
  929. `called-login STRINGS'
  930.      The first STRING specifies the login name that the system must use
  931.      when calling in.  If it is `ANY' (e.g. `called-login ANY') any
  932.      login name may be used; this is useful to override a file-wide
  933.      default and to indicate that future alternates may have different
  934.      login names. Case is significant.  The default value is `ANY'.
  935.      Different alternates (*note Defaults and Alternates::.) may use
  936.      different `called-login' commands, in which case the login name
  937.      will be used to select which alternate is in effect; this will
  938.      only work if the first alternate (before the first `alternate'
  939.      command) uses the `called-login' command.
  940.      Additional strings may be specified after the login name; they are
  941.      a list of which systems are permitted to use this login name.  If
  942.      this feature is used, then normally the login name will only be
  943.      given in a single `called-login' command.  Only systems which
  944.      appear on the list, or which use an explicit `called-login'
  945.      command, will be permitted to use that login name.  If the same
  946.      login name is used more than once with a list of systems, all the
  947.      lists are concatenated together.  This feature permits you to
  948.      restrict a login name to a particular set of systems without
  949.      requiring you to use the `called-login' command for every single
  950.      system; you can achieve a similar effect by using a different
  951.      system file for each permitted login name with an appropriate
  952.      `called-login' command in the file-wide defaults.
  953. `callback BOOLEAN'
  954.      If BOOLEAN is true, then when the remote system calls `uucico'
  955.      will hang up the connection and prepare to call it back. The
  956.      default is false.
  957. `called-chat STRINGS'
  958. `called-chat-timeout NUMBER'
  959. `called-chat-fail STRING'
  960. `called-chat-seven-bit BOOLEAN'
  961. `called-chat-program STRINGS'
  962.      These commands may be used to define a chat script (*note Chat
  963.      Scripts::.) that is run whenever the local system is called by the
  964.      system being defined.  The chat script defined by the `chat'
  965.      command (*note Logging In::.), on the other hand, is used when the
  966.      remote system is called.  This called chat script might be used to
  967.      set special modem parameters that are appropriate to a particular
  968.      system.  It is run after protocol negotiation is complete, but
  969.      before the protocol has been started.  See *Note Logging In:: for
  970.      additional escape sequence which may be used besides those defined
  971.      for all chat scripts.  There is no default called chat script.  If
  972.      the called chat script fails, the incoming call will be aborted.
  973.